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Technical field 

15 The present invention is directed generally to automated advice 

and selection, and more particularly to a method and apparatus which is 
able to quickly and efficiently process a large number of rules, based 
upon a user supplied profile, to provide a categorized set of 
recommendations and selection criteria, and also to select objects in an 

20 efficient and rapid manner from a large inventory of possible objects 
based upon the categorized set of selection criteria. 

Background 

Although the present invention will be described in the context of 
25 a fashion example, it is to be understood that the concepts and 

techniques described in this application are applicable to a wide variety 
of situations in a variety of fields. There is no intent by use of an 
example in the fashion area to limit the scope of the inventions claimed 
in this application. It is believed that describing the present invention in 
30 the context of a fashion example will render the invention more easily 
understood, the fashion context being more generally familiar, but 
nonetheless as complex and variation-intensive as more technologically 
advanced scenarios. 
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Dressing oneself is not always easy. Many questions typically run 
through a person's mind while trying to select clothing. Does this make 
me look fat? What color shoes go with this outfit? Is this still in style? 
What should I wear? Tens of thousands of these questions are sent to 
5 style columnists across the nation every day, while hundreds of 
thousands more are asked of retail salespeople. But millions go 
completely unanswered, resulting in the inquirer choosing apparel that is 
not right for their body, for their color tones, or for the event they are 
attending. 

10 Several attempts have been made to connect apparel customers 

with retailers via the World Wide Web fWeb"). High customer 
acquisition costs and poor customer retention rates have resulted in 
disappointing returns for most consumer apparel websites. These poor 
returns are primarily due to consumers having difficulty in locating 

15 precise items, the inherent inability to touch or try on garments, a 

cumbersome, delivery-based return/exchange process, and the lack of 
personal assistance. While online apparel shopping offers many unique, 
interactive possibilities, it can never fully replace visiting a store to shop 
for clothes. 

20 Most consumer apparel websites are backed by companies that 

stock and ship apparel directly. These companies do not offer 
sophisticated, automated advice, nor have robust search capabilities. 
Many magazines and webzines offer style opinions to their niche 
audience. However, such advice is neither fully personalized nor 

25 comprehensive. 

Among the difficulties of offering sophisticated, automated advice 
is that conventional artificial intelligence methods and systems require 
sophisticated programming techniques, high performance server 
systems to process the artificial intelligence applications, and highly 

30 trained personnel to administer. The more sophisticated and detailed the 
user-supplied input, the more complex and computationally intensive the 
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conventional artificial intelligence solution. Updating or maintaining the 
domain knowledge for such systems can prove to be arduous tasks. 

For example, a conventional method for approaching the fashion 
advice problem is to use an extensive series of "if-then" statements to 
5 address each of the possible combinations of user requirements and 
clothing attributes. A drawback of such an approach its sheer size and 
complexity if all feasible combinations are to be handled. 

It is therefore desirable to provide an artificial intelligence based- 
automated advice methodology and system which avoids the 

10 cumbersome knowledge representation and heavy computational 
requirements of conventional approaches, yet can accommodate 
detailed user requirements and a large number of possible variations in 
the characteristics of the possible choices. In a fashion context, this 
artificial intelligence based method and system closely duplicates a 

15 clothing and accessory style consultant, also known as a "personal 
shopper." 

Brief Summary of the Invention 

The above and other problems and disadvantages of prior 

20 automated advice methods and systems are overcome by the present 
invention of a method, and apparatus therefor, of providing advice and 
forming criteria based on the advice for selecting objects out of an 
inventory of available objects. The formulated criteria are based upon 
user-supplied profile information, a set of object characteristics, and a 

25 set of rules which have been formed by associating a set of variations of 
the object characteristics with a set of variations of input variables. In 
accordance with the present invention, each variation in object 
characteristics is associated with each variation in input variables, and a 
priority is assigned to each such association to form a prioritized rule 

30 set. The user-supplied profile information is analyzed to select specific 
variations from the set of variations of input variables. The selected 
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input variable variations are applied to the prioritized rule set to obtain a 
reduced set of prioritized rules. The reduced set of prioritized rules are 
processed to generate categorized output characteristic values which 
represent the advice and the criteria for selecting objects. 
5 In a further aspect of the present invention, a method and 

apparatus are provided for selecting objects from an inventory of 
objects, each object being described by a set of characteristics and by a 
value for each characteristic in the set of characteristics, where, for a 
particular object the assigned values of the characteristics for that 

10 particular object are descriptive thereof. In accordance with the present 
invention, a set of desired characteristic values is formed. A branched 
path search schema is formed as a function of the desired characteristic 
values, output characteristic passing criteria, and supplied search order 
criteria. Objects from the inventory of available objects are evaluated 

15 according to the branched path search schema. The evaluated objects 
are then ranked according to how well the object traversed the 
branched path search schema. 

The present invention provides a straight forward yet 
sophisticated methodology and structure for accommodating detailed 

20 user requirements and a large number of possible variations in the 
characteristics of the possible choices to provide a set of well-informed 
recommendations, while avoiding the heavy computational requirements 
of conventional approaches. 

These and other advantages of the present invention will be more 

25 readily understood upon considering the following detailed description of 
the present invention, and the accompanying drawings. 



Brief Description of the Drawings 

Figurel is a simplified functional block diagram of the advice 
30 engine and the object selection methodology of the present invention 
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Figure 2 provides a more detailed functional block diagram of the 
advice engine processing in accordance with the present invention. 

Figure 3A and 3B provide a example of the kinds of user profile 
input data which might be provided in connection with the present 
5 invention, and a specific example in the fashion context. 

Figures 4A to 4L provide examples of input variables, variations of 
such variables, and values assigned to such variations of input variables. 

Figure 5 illustrates the conversion process by which the user 
profile input data is used to select particular input variable values. 
10 Figure 6 is an example of a pre-ordered input variable array 

which is the result of the conversion process illustrated in Figure 5. 

Figure 7 illustrates a theoretical knowledge matrix and the 
relationship between input variables, input variable variations, object 
characteristics and variations of object characteristics, and assigned 
15 priorities. 

Figure 8 illustrates the use of the pre-ordered input variable array 
of Figure 6 to trigger portions of the matrix which are related to the 
input variable variations set forth in Figure 6. 

Figure 9 is an illustration of a theoretical reduced matrix in 
20 accordance with the present invention, and demonstrates the 

relationship between input variables, the object characteristics, and the 
associated priorities. 

Figures 10A to 10Q illustrate object characteristics and variations 
of such characteristics in the fashion context in the form of pre-defined 
25 user input and garment characteristic categories. 

Figures 11A to 11D illustrate a reduced matrix and output 
characteristics for the problem of fashion, and the processing of input 
variable weights, assigned priorities, and exclusions rules in accordance 
with the present invention. 
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Figure 12 provides a more detailed functional block diagram of 
the object selection methodology in accordance with the present 
invention. 

Figures 13A to 13E illustrate the use of output characteristic 
5 values, search order, value and passing standards in accordance with 
the present invention for the problem of fashion. 

Figures 14A to 14D illustrate a branched search engine generated 
for the output characteristic searching order, values and passing 
standards set forth in Figures 13A to 13E. 
10 Figures 15A and 15B provide an example of a characterized 

inventory database for the problem of fashion. 

Detailed Description of the Invention 

In the specific fashion example described, a system and method 

15 are described for apparel advice automation over a network, such as the 
World Wide Web ("Web"). 

User of websites typically browse through websites by "clicking" 
with a computer mouse through a series of strategically organized 
hyperlinks. On the other hand, consumers of retail outlets browse 

20 through apparel by physical walking through "Brick & Mortar" stores that 
stock the apparel. A system that provides a connection between 
website users and physical retails stores is preferably referred to as a 
"Click & Mortar" model. The apparel advice automation described herein 
will provide the apparel industry with an improved Click & Mortar model 

25 for apparel, an extremely "high-touch" product. 

At least five primary tools are described to increase apparel 
websites' "stickiness" and personalization, facilitate specific product 
searches, drive traffic into Brick & Mortar stores, and create a 
centralized place for consumers to search for clothing at local outlets. 

30 These tools preferably include: 
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1. An "expert" that supplies highly personalized, occasion 
specific clothing advice, equal to or better than that of a professional 
style consultant which then allows for the purchase of specific clothing 
choices based on the advice; 
5 2. An industry standard XML ontology and centralized 

database of detailed product features allowing for extremely specific 
product searches; 

3. Customizable consumer portal software and email 
notifications that are regularly updated with new inventory, style and 

10 seasonal recommendations; 

4. A turnkey solution that allows consumers to place an item 
on hold at a local store to be tried on before purchase, or (depending on 
the retailer's needs) purchase a garment online then pick it up at a local 
store; 

15 5. A "portal" based on the aforementioned technologies, the 

portal allowing consumers to search through a database of products 
rather than individual stores. This portal can include sticky features 
such as gifting advice, daily outfit assessments, garment design & find, 
continually updated information on fashion trends, feedback to 

20 designers on their latest lines, discussion groups, chat rooms, expert 
style columnists, style testimonials, fashion police citations, user's style 
photo gallery, streaming video of runway shows, and more. 

The "expert" identified above will be the primary focus of the 
detailed description provided herein. 

25 In the fashion example, a "Website" is provided which is centered 

around the "expert" advice method and apparatus, and is preferably 
configured to produce comprehensive written reports with illustrations of 
recommended attire. Clothing experts provide expert information to a 
database associated with the "Website." These clothing experts work 

30 directly with designers to display actual examples of clothing articles in 
the advice reports. As inventory is added, an extensive database of 
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well-described products is developed, allowing for precise searches of 

specific products. 

In one version, links are provided to designers' website. Major 

fashion magazines are engaged by offering free advertising on the 
5 Website in exchange for positive articles about the Website. As the 

Website brand, traffic and credibility builds, retailers may be approached 

to fulfill the demand generated for the products displayed. Items are 

delivered through a retailer's existing shipping infrastructure, or a fax is 

sent to a local store's customer service department to inquire about 
10 availability. 

To complete the overall solution, appropriate database 

technologies are utilized for robust integration of local retail inventories 

with the Website. Ultimately, an application service provider ("ASP") 

sells the complete service and/or individual technologies to apparel e- 
15 tailers, portals, and style webzines. Once registered with a personalized 

profile, consumers will find their profile on all sites using technology of 

the present invention. 

The present invention may be used in connection with marketing 

efforts to target people discontent with their physical appearance or with 
20 their social/romantic status. The technology may also be used to target 

online body-conscious women, and single men. Combined, these two 

groups represent 31 million people. 

There are over 100 large apparel retailers in the U.S. along with 

thousands of smaller stores suitable for using technology of the present 
25 invention. Mid-range to high-end department stores, such are also 

suitable users. 

Conceptually, in accordance with the present invention a user is 
prompted to complete a profile, which the system understands and uses 
to trigger applicable rules in a knowledge matrix. The triggered rules are 
30 summarized to exclude conflicts and determine the output characteristic 
values (which define the optimal characteristics). In conjunction with the 
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preset categorized, output characteristic searching order and output 
characteristic passing standards, these output characteristic values are 
fed into the searching schema, generating in an individualized search 
engine for each distinct profile. This search engine queries the 
5 characterized inventory database ultimately resulting in prioritized 
inventory selections (again unique to each profile). 

Referring to Figure 1, the present invention will now be described 
in greater detail. The present invention has two distinct parts which can 
function independently of one another: an advice engine 10, and an 
10 object selection methodology 12. 

Advice engine 10 takes in a user input profile 14, uses the 
information from the user input profile 14 to select input variables 16 
which trigger rules in a knowledge matrix 18. In turn, these triggered 
rules 20 are evaluated and processed in a processing block 22. The 
15 result of the processing in block 22 is a set of categorized output 
characteristic values 24. 

The object selection methodology 12 uses information such as 
the set of categorized output characteristic values 24, a search order 26, 
and passing criteria 28 in a search schema forming operation 30. The 
20 result of the search schema forming operation 30 is a branched path 
search engine 32 which can be individualized or customized to a 
particular user or set of circumstances. 

Characterizations of objects, such as fashion items which have 
been characterized and stored in an inventory database 34, are 
25 subjected to the branched path search engine 32, evaluated, and 
ranked. The result is a prioritized inventory selection list 36, which is 
the output of the object selection methodology and system 12. 

Advice Engine ~ Criteria Formation 
Additional details about advice engine 10 are provided in Figure 
30 2. The user profile input 14 can be an array of information upi(i) as in 
Figures 3A and 3B, which will be described in detail below. The user 
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profile input 14 is converted in a conversion process 38 into the select 
input variables 16 which are formed into a pre-ordered input variable 
array 40. 

In order to form the pre-ordered input variable array 40, the 
5 conversion process 38 uses a set of input variables each of which has a 
number of defined variations. Depending upon information supplied in 
the user profile input 14, different variations of the input variables will 
be identified. 

The pre-ordered input variable array 40 is applied to knowledge 

10 matrix 18 to trigger corresponding portions of the matrix. Knowledge 
Matrix 18 associates the possible variations of the input variables with 
the possible variations of the characteristics, and assigns priorities to 
each combination of input variable variation and characteristic variation. 
These triggered portions or rules 20 of knowledge matrix 18 are 

15 used to form a "reduced knowledge matrix" 42. The "reduced 

knowledge matrix" 42 is then evaluated (see function 22, Figure 2) to 
generate the "categorized output characteristic values" 24. 

Figure 3A illustrates an example of an array of user profile inputs, 
with eighteen (18) elements or pieces of information making up the 

20 array. It is to be understood that the number of elements in the array 
will be determined by the requirements of the particular application and 
the level of detail desired for the particular advice task. 

Figure 3B provides an example of the user profile input array for 
the fashion example. As can be seen from this example, the 

25 information supplied by the user is of the type which will aid in the 
selection of the objects of interest, in this case garments and fashion 
accessories. For example, the nature of the specific event, whether, 
formal, informal, or other, will impact the kinds of garments which 
would be appropriate. The time of day, as well as the date of the event, 

30 will also dictate whether a light weight or heavier material is most 
suitable. Information about the user's body, both objective and 
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subjective are, aiso requested. In other applications, such as advice on 
consumer electronics selection, or other retail scenarios, the information 
to be supplied by the user will be different. For example, for the 
consumer electronics scenario, for audio reproduction equipment, the 
5 user will be asked about listening preferences, room sizes, music 
sources, and the like. 

Figure 4A to 4L illustrate possible input variables for the fashion 
example, and the possible variations which have been defined for each 
such variable. For example, Figure 4E corresponds to the input variable 

10 of "time" and defines three variations: ml - morning; m2 - afternoon; 
and m3 - evening. Figure 4K defines the variable age, "age#," and 
defines eight (8) variations. Some input variables, such as 
height/weight, "htwt," represent combined or related profile information, 
while others, such as body type, "btyp," include a subjective element. 

15 Figures 5 and 6 illustrate how the user profile information 

obtained in Figures 3A and 3B are subjected to several calculations that 
convert it into pre-defined categories, Figures 4A to 4L, which are in 
turn assembled into a pre-ordered input variable array, u(j), Figure 6. 
In the fashion example, illustrated in Figure 6, the pre-ordered input 

20 variable array has thirteen elements. 

In Figure 5, the user profile input is provided in the left most 
column. The center column illustrates the calculations. The right-most 
column illustrates the calculated "input variable" variation. It can be 
seen, for example, that input variable u[5] has been set equal to "t4." 

25 From Figure 4F it can be seen that "t4" is one of the variations of the 
body type, "btyp," input variable. In Figure 4F, "t4" corresponds to the 
"well proportioned" variation. Referring back to Figure 5, it can be seen 
that the "well proportioned" calculation was made using the user profile 
input of "bust" and "waist" and "hips." Other calculations and the user 

30 profile input used for such calculations are shown in Figure 5. 
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The pre-ordered input variable array of Figure 6 is used to trigger 
applicable rules in the knowledge matrix 18, see Figure 1. More 
particularly, the input variable array triggers analogous columns in the 
knowledge matrix 18, an extensive, weighted, 2 dimensional knowledge 
5 matrix that supports all feasible input conditions. In use, this knowledge 
matrix is populated with real numbers that represent prioritized 
rules(prjj), used in calculating the output characteristic value (oq) for 
the expert system. Each column in the knowledge matrix cab be 
weighted by a variable multiplier (wj). 

10 Referring to Figure 7, a simplified, conceptual illustration of the 

knowledge matrix 18 is provided. It is to be noted that the knowledge 
matrix 18 is arranged in groups of columns and groups of rows. Each 
group of columns represents an input variable, and the variations for 
that input variable. Each group of rows represents a characteristic and 

15 the variations for that characteristic. At the intersection of each column 
and row is a "priority." The priority is assigned to indicate the 
importance of that combination of the particular input variable variation 
and characteristic variation, with respect to other variations of that 
characteristic. 

20 For example, in Figure 7, the first group of columns represents an 

input variable xl, and variations of vl through v6 of input variable xl. 
The first group of rows represents characteristic cl, and variations aO to 
a3 of characteristic cl. The priority assigned to the combination of xlvl 
and claO is a low "p9." On the other hand, the priority assigned to the 

25 combination of xlvl and clal is a relatively high priority of "p2." In this 
manner, a large number of combinations of input variable variations and 
characteristic variations are represented in the knowledge matrix 18, 
and a priority is assigned to each such combination. 

Figure 8 illustrates the knowledge matrix 18 of the present 

30 invention applied to the fashion example, and the manner in which 
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triggers from the pre-ordered input variable array 40 of Figure 6 are 
used to select certain columns from the knowledge matrix 18 for further 
processing. It is to be noted that the embodiment of the knowledge 
matrix 18 shown Figure 8 also includes a row which assigns "weights" to 
5 each of the input variable variations. As will be described in greater 
detail herein below, these "weights" can be changed which in turn will 
affect selection outcome. 

Three of the triggers, or input variables, from Figure 6, el, si, 
and m3, are shown in Figure 8. These "trigger" respective columns in 

10 the knowledge matrix 18. These and the other "triggered" columns are 
used to form the "reduced knowledge matrix" 42. See Figure 2. In 
other words, The triggered columns in the knowledge matrix form a 
reduced matrix that is likewise affected by variable multiplier. The 
applicable, non-excluded, prioritized rule values in the reduced matrix 

15 are averaged to generate the final output characteristic values. These 
values dictate which output characteristic is most favorable. 

The following equation characterizes the relationship between the 
knowledge base matrix, input variable and output characteristic array: 



20 




= (triggered) system input variable array 



= (comprehensive) system input variable array 



pry = priority rule values for the knowledge (and reduced) 



25 



matrix 



Wj = weighted multiplier 
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S e R [1.0. ..3.0] = predefined range of real numbers that dictate 

priority in the knowledge matrix 18. Note that for the purposes of the 
fashion example, the range of real numbers from 1.0 - 3.0 dictate an 
applicable, non excluding priority value. The real number 0.0 denotes a 
5 'don't care' or 'no effect' priority. The real number 9.0 indicates 'exclude 
this characteristic entirely.' 

ocj represents the sum of all triggered prioritized rules pry in the 
row (i), multiplied by the weights Wj of each triggered column Uj . The 
result of which is divided the number of triggered rows in the set S 
10 (that contain applicable rule values R [1.0. ..3.0]) 

Turning to Figure 9, a "reduced knowledge matrix" 42 is 
illustrated conceptually. Note that there are fourteen (14) columns, 
thirteen (13) of which correspond to the input variables from the pre- 
ordered input variable array 40. While the number of columns in 
15 reduced knowledge matrix 42 are reduced in comparison to knowledge 
matrix 18, it is to be noted that the full compliment of characteristic 
variations (rows) have been preserved. 

Figures 10A to 10Q illustrate for the fashion example, the 
characteristics of the garments of interest, and their variations, which 
20 are used to populate the rows of the knowledge matrix 18. For 

example, Figure 10B represents the "fit" for a garment "top," and uses 
the symbol "ft." Possible variations of the "garment fit top" 
characteristic include "ftO = loose and ftt2 = fitted. 

Figure 10J specifies the "garment material" characteristic, and 
25 identifies variations such as "mata" = silk; "mat4" = wool; and "mat9" = 
rayon. Similarly, Figure 10K corresponds to the "garment pattern" 
characteristic, and has pattern variations including "patO" = solid; "pat5" 
= paisley; and "pat8" = other. 

Figures 11A to 11D illustrate a reduced knowledge matrix 42 
30 which contains working numbers for the fashion example. Also 
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illustrated in Figures 11A to 11D is the processing which is performed 
using the listed priorities and the column weights to obtain output 
characteristic values 24. 

Taking the "nckl" row as an example, it can be seen that the 
5 processing includes multiplying the weight for a column by the priority 
assigned to the row/column combination, and then repeating the 
operation for all columns, summing the products, and then dividing the 
sum by the number of non-zero products. In the case of the "nckl" 
row, there are two non-zero products which result in a 5.5 value for the 
10 "nckl" characteristic. From Figure 10C it can be seen that the "nckl" 
characteristic variation corresponds to a "neck lined" garment 
characteristic. 

In a similar manner, for the "slv6" row the value for the "slv6" 
characteristic is determined to be "3." From Figure 10G it can be seen 

15 that the "slv6" characteristic variation corresponds to a "long sleeve" 
garment feature. 

It is to be noted that when the value of "9" appears as a priority 
for any of the characteristics, that characteristic is excluded from the 
output characteristics. Thus, in Figures 11A to 11D, it can be seen that 

20 a number of the characteristics are excluded because a "9" appears in at 
least one of the columns, and such exclusion in indicated by an 
"excluded" symbol, 0. 

The right-most column in Figures 11A to 11D represents the 
categorized output characteristic values 24 for the fashion example, 

25 which is a result produced by the advice engine in accordance with the 
present invention. In particular, for the fashion example, this result 
provides a list of garment characteristics, possible variations for each 
garment characteristic, and a prioritization for such features and 
variations. The resulting output characteristics are arranged into 

30 predefined categories. The output characteristic in each category with 
the lowest overall value is defined as optimal. Successively, the 
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remaining non-excluded output characteristics are prioritized 
accordingly. 

Therefore, for the user whose user profile was provided for the 
fashion example of Figures 11A to 11D, the garment fit should be "fft2" 
or normal with a fairly low priority of 8.6; the highest priority variation 
for garment neck is ,l nck4," or low-cut with a priority of 3.5; the 
garment leg should be "legl" or "bell" with a priority of 2; and so on. 
See Figures 10A to 10Q. 

It is to be noted that a number of different weights have been 
applied to the columns in the fashion example of Figures HA to 11D. In 
this example, the lowest weights represent input variables which are to 
have the highest impact on the outcome. For example, input variables 
m3, d2, and bl have been assigned weights of "1." From Figures 4A to 
4L it can be seen that these input variables correspond to: m3 = time 
of day - evening; d2 = endowment - average; and bl = best body 
feature - arms. Conversely, de-emphasizing weights of "5" were 
assigned to input variables "h7" and "t4," which represent: h7 = 
height/weight - tall and thin; and t4 = body type - well proportioned. 
Object Selection Methodology 

Referring to Figure 12, the objection selection methodology of the 
present invention will now be described in greater detail. The searching 
schema utilized in this system is an ordered search. Its organization is 
dictated by the categorized output characteristic search order 26. This 
order can be either preset or determined by utilizing the user profile that 
accesses an additional knowledge base. The output characteristic 
passing standard 28 sets the maximum output characteristic value 
permissible for progression to the next category (as dictated by the 
categorized output characteristic search order 24) in the search schema. 

Once an individualized search engine 32 is fashioned from the 
above information, objects or items from the characterized inventory 
database are subjected to the individualized search engine 32. As an 
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object progresses through the individualized search engine 32, a score is 
kept of how well the item satisfies the search criteria. For example, the 
score might be incremented for each level successfully passed, and 
decrement by a like amount for each level not successfully passed. 
5 Figures 13A to 13E provide an example using the problem of 

fashion for each of search order, passing criteria, and categorized output 
characteristic values which are used to form the individualized search 
engine. In the figures, the left-most column identifies the output 
characteristic category, the second column represents a designated 

10 search order for each of the characteristic categories, the third column 
represents the "output characteristic values" from the advice engine, 
and the fourth column represents provided "passing standards." For 
example, the "garment occasion" category is the third priority to be 
considered in the search. The passing standard for the "garment 

15 occasion" category is "4," which rules out garments which are for 
"occ3," "occ5," and "occ6." 

Similarly, for the "garment color tone" characteristic category, the 
search priority is an "8," indicating that it will be the eight characteristic 
considered. The passing standard is "5," which result in "tnel" = light, 

20 and "tne2" = bold being excluded. 

Figures 14A to 14D illustrates the individualized branched path 
search which was formed from the information in Figures 13A to 13E. 
Consistent with Figures 13A to 13E, the "garment gender" characteristic 
category 44 is searched first, followed by the "garment type" category 

25 46. Thereafter, "garment occasion" 48 and then "garment season" 50 
are searched, all in accordance with the "search order" column in 
Figures 13A to 13E. 

In Figures 14A to 14D, the bolded characteristic variations 
indicate ones which meet the "passing standard" for that characteristic. 

30 Thus, for the "garment occasion" block, only "occl" and "occ2" are 
bolded in view of the indicated passing standard of "3." These bolded 
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characteristics indicated the possible valid paths that can be taken 
through the search level. The non-bolded characteristics are considered 
to be excluded from the possible paths which may be taken through the 
search level. 

This individualized search engine 32 of Figures 14A to 14D 
queries the characterized inventory database 34, accumulating the 
output characteristic values for its corresponding path. The 
characterized inventory that does not map directly to the path dictated 
by the search engine accumulates a penalty for every non-matching 
stage. The result of the search engine's query is a score for each 
inventory item that represents how well it maps to the optimal output 
characteristics. 

Figure 15A and 15B illustrate a characterized inventory database 
which may be queried by the search engine 32 of Figures 14A to 14D. 
(In these figures, the number "0" represents a "don't care" or "no 
effect" priority, and the number "9" represents an "exclude this 
characteristic entirely" indication.) For example, examining the second 
item in the inventory, starting from the "garment type" characteristic 46, 
it can be seen in Figure 15A that all of the garments in the inventory are 
type 1 and type3, which satisfies the "garment type" characteristic 46. 
For the next characteristic to be checked, "garment occasion," the 
second item in Figure 15A is a type 2 or type 4, which meets the 
criteria. In this manner, the garments in inventory are queried by the 
search engine 32, and a prioritized inventory selection 36 is provided. 

Because of the efficient structure of the advice engine 10 and the 
search engine 12 of the present invention, an advice system and object 
locating methodology is provided which is quick and flexible. The system 
of the present invention is also scalable, and can support the addition of 
numerous rules on an ongoing basis as the system is improved to 
provide increasingly more detailed advice. Further, because of its 
simplicity, the present invention can support to addition or changes in 
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input and output variable (for example, as additional garment and 
accessory items are added). 

As can be appreciated from the foregoing description of the 
present invention, customization of rules for individual user or e-tailer's 
5 needs (/. e. f an e-tailer may want to increase the likelihood that a certain 
garment is recommended), as well as an ability to add and change 
different rules as seasons and trends change, can be readily 
accommodated. Changes in fashion trends can be reflected in the 
priorities given to each characteristic/input variable combination; and 

10 weights given to the input variables can be used make further 

refinements as fashion trends shift the emphasis to different features. 
Changes in search order as well as the passing criteria can also be used 
to after the advice given by advice engine 10, and the garments selected 
by selection methodology 12. 

15 It can also be appreciated that because of the architecture of the 

present invention, additions and deletions from the inventory database 
are simple and easy to make. 

The present invention is particularly suitable to be implemented in 
a conventional personal computer, web server, or the like. 

20 As can be appreciated from the foregoing, the system and 

method of the present invention, as illustrated in the network based 
automation of apparel advice and selection embodiment, is fast, 
efficient, expandable, scaleable, maintainable, reusable and suitable for 
solving a wide variety of other complex, real world problems. 

25 It is to be understood that the method and apparatus of the 

present invention, while described in the context of a retail fashion 
example, is equally applicable and suitable for use in a wide variety of 
other areas. For example, the present invention can be used in 
specifying and selecting components in the electronics industry based 

30 upon user-supplied required features, performance and cost. Other 
applications or uses of the present invention include the other retail 
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scenarios, or any situation where many variables and variations must be 
applied to many possible choices, in the context of a large body of 
selection rules. The present invention is likewise capable of 
incorporating feedback loops to support iterative or real time thinking 
scenarios. 

Attached hereto on pages 51 through 71 is an Appendix of code 
listings, data and definitions, which provide further detail about the 
fashion example of the present invention. 

It is to be understood that the term "objects" as used herein can 
refer to anything that has characteristics associated with it. An example 
might be an army moving across a battlefield and a characteristic might 
be it's speed, direction, size, etc. Therefore, the term "object" is not 
meant to be limited solely to physical or inventory objects. The system 
could be used to just create best parameters for an "object" at any 
given time. 

The present invention has been described above with reference 
to a fashion embodiment. However, those skilled in the art will 
recognize that changes and modifications may be made in the above 
described embodiments without departing from the scope of the 
invention. For example, the present invention is applicable to any 
scenario in which a large number of decisional rules, characteristics, and 
input variables are involved. Furthermore, while the present invention 
has been described in connection with a specific processing flow, those 
skilled in the are will recognize that a large amount of variation in 
configuring the processing tasks and in sequencing the processing tasks 
may be directed to accomplishing substantially the same functions as 
are described herein. These and other changes and modifications which 
are obvious to those skilled in the art in view of what has been 
described herein are intended to be included within the scope of the 
present invention. 
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APPENDIX 

CONTENTS 

1) screenshot of the USER INPUT PROFILE (figure 1- 14), 

2) the code that converts the user input profile to usable info for 
the knowledge matrix (figure 1-16) 

3) the KNOWLEDGE MATRIX (figurel- 18) 

4) the code that does the PROCESSING FOR CATEGORIZED 
OUTPUT -CHARACTERISTIC VALUES (figurel- 22) 

5) the CATEGORIZED OUTPUT -CHARACTERISTIC SEARCH 
ORDER (figurel- 26) 

6) the OUTPUT CHARACTERISTIC PASSING CRITERIA (figurel- 

26) 

7) the SEARCHING SCHEMA/ RULES (figurel- 30) 

8) the CHARACTERIZED INVENTORY DATABASE(figurel- 34) 

9) screenshot of the advice and PRIORITIZED INVENTORY 
SELECTIONS (figurel- 36) 
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1) screenshots of the USER INPUT PROFILE ffiaure 1- 14) : 

GUIDE STVL5 
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2) the code that converts the user input profile to usable 
information for the knowledge matrix ffiaure 1-161 : 
/** 

* Clean Version 3.0 

* Works with GuideAII Version 3.0 

* and GetScore3 Version 3.0 

* Keep Vectors for both Garmets files and 

* full sorted scores for G arments. 

* Accept user parameters through constractor. 

*/ 

// package guide; 

// import util.Arguments; 
import SortAttribs; 
import MyComparator; 
import java.util.*; 
import java.io.*; 

import java.io.OutputStreamWriter; 
import java.io.PrintWriter; 



public class GetScore2 { 



private static final int maxCol = 83; 

private static final int maxRow = 21 ; 
private static final int maxChoice = 12; 
private static final int maxSheCol = 176; 

public static final int maxAttrib = 21; 

public int[] userChoicel = new int[maxChoice+1]; 

private Vectorrj tokenVector = new Vector[maxRow+1]; 
private VectorQ choiceVector = new Vector[maxRow+1]; 

public Vectorrj resultVector = new Vector[maxAttrib]; 

public int[] garmentNumber = new int[20]; 
private Vector attribFullName = null; 

public int garmentReturns = 0; 

private int maxRet = 21; 

private int maxGType = 7; 

public VectorQ recGarmentType = new Vector[10]; 

public LineNumberReader InReader = null; 
private StringfJ attribName = new StringQ {"gt1gt0","gt1gt2","gt1gt3","gt1gt4", 

,, gt1gt5 ,, l "gt6gt1","gt2gt0","gt2gt3", 

"gt2gt4","gt2gt5' , ,"gt6gt2","gt3gt0" > 

"gt3gt4","gt3gt5","gt6gt3","gt4gt0", 
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"gt4gt5","gt6gt4",' , gt5gt0","gt6gt5", 
"gt6gt0"}; 

private SiringQ userlnputShortName = new StringQ {"evnt'V* 0 */,"sesn'7* 1 
7,"time7* 2 7, 

"htwt"/* 3 7,"btyp7* 4 7,"endw7* 5 7, 

"bfit"/* 6 7,"bst17* 7 7,"bst27* 8 7, 

"wrst7* 9 7,"sty17* 10 7,"age7* 1 1 7, 

"she"/* 12 7}; 
private StringD userVarsName = new String[30]; 

// {"evnt"/* 0 7,"sesn7* 1 7,"time7* 2 7,"feet7* 3 7, 

// "inchs7* 4 7,"pounds7* 5 7,"waist7* 6 7, 

// 

"bust7* 7 7,"cup"/* 8 7,"hips7* 9 7,"bfit7* 10 7, 

// 

"bst17* 11 7,"bst27* 12 7,"wrst7* 13 7, 

// 

"styi7* 14 7,"age7* 15 7,"hair7* 16 7, 

// 

"skin7* 17 7,"eye'7* 1 8 7,"zipcode7* 19 */}; 
public String[] userProfile = new String[maxChoice+1]; 

private int[] userlnputGroupN umber = new intfl {13, 4, 3, 9, 5, 4, 3, 7, 7, 9, 1 1, 8 }; 
public String]] userVarsInput = new String[19]; 
public Vector sheColArray = null; 

public Properties props = null; 

private String switchl = "no"; 
private String switch2 = "no"; 
public String switch3 = "allchoices"; 
private String switch4 = "no"; 

private boolean printYes = false; 
private int rowN = 0; 
private String propFile; 

public Vector colArray = null; 
private Vector rowArray = null; 
public Logger logger; 

GetScore2 (Properties props, String^ userArray) { 

this.props = props; 

this. userVarsName = userArray; 

} 



* get Column and Row information 

* create column/Row arrays 
7 
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public void getColumn() 
{ 

colArray = new Vector(); 
for (int i =0; i<maxCol;i++ ){ 

String gString = "guide.col"+i; 

coiArray.add(props.getProperty(gString, null)); 

} 

// she column 

sheColArray = new Vector(maxSheCol); 
for (int i =0; i< maxSheCol;i++ ){ 

String gString = "guides. shycol"+i; 

sheColArray.add(props.getProperty(gString, null)); 

} 

// String logfilel = props.getProperty("log1 .file","c:/temp/style.log"); 

// loggerl = new SimpleLogger(logfilel); 

// 

// logger.debug(2,"ln getScore2 constructor"); 

r 

String logfile = props.getProperty("log.file","c:/temp/style.log"); 
logger = new SimpleLogger(logfile); 

logger.setLevelFilter( Logger.DEBUG ); 
logger.debug(2,"ln getScore2 constructor"); 

*/ 

} 

!** 

* create buffer reader for read actual data 

*/ 

public void readData() 
{ 

try 
{ 

// switchl = props.getProperty("attrib.bestscore", "no"); 

switch2 = props.getProperty("attrib.allscore", "no"); 
switch3 = props.getProperty("user.from", "allchoices"); 
switch4 = props.getProperty("choice.show", "no"); 

String dir = props.getProperty("garment.directory", "d:/temp"); 
String fl1 = props.getProperty("garmenttype.fiie", "dresses.txt"); 
File dataListl = new File(dir.fH); 
BufferedReader listlnl = new BufferedReader( 
new FileReader(dataListl)); 
lnReader= new LineNumberReader(listlnl); 

} 

catch(FileNotFoundException e) 
{ // Stream creation exception 
System.err.println(e); 
return; 

} 

catch(IO Exception e) // File read exception 

{ 

printfError reading input file" + e ); 
return; 
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} 



public void findUserColumns() 

{ 

if (switch3.equals("allchoices")) { 

r 

* Provide column numbers for all inputs parameters 

* criate input numbers array 

* all entries are from lookup tables as position in an 

appropriate array 

*/ 

// find derived variables 

// find height/weight group number 
findHeihtWeightO; 

// find body type and endowement based on waist, 

// bust and hips dimensions 
findBodyTypeEndw(); 

// Find skin/hair/eye abbriviation 
findHSEnumber(); 



// Find rest input numbers 

findRestlnput(userChoicel, colArray); 

} 

else{ 

StringQ uChoice = new String[maxChoice]; 
for (int i=0;i<maxChoice ;i++ ) { 

String index = "user.choice"+i; 
uChoice[i] = props.getProperty(index, null); 
userChoicel[i] = lnteger.parselnt(uChoice[i]); 
// iogger.debug(2," User choice "+uChoice[i]+" for i "+i+" Position Number 

"+userChoicel); 

} 

} 

// print uChoice 
// StringQ uChoice = new StringfmaxChoice]; 

for (int i=0;i<maxChoice+1 ;i++ ) { 

String index = "user.choice"+i; 
// uChoice[i] = props.getProperty{index, null); 

// userChoicel[i] = lnteger.parselnt(uChoice[i]); 

// logger.debug(2," User choice "+userChoicel[i]+" for i "+i); 

} 

} 

/** 

* Find height/weight group according to user input 

*/ 

public boolean findHeihtWeightO 
{ 

boolean goodHeghtWeight = true; 
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String feetS = userVarsName[3]; 

String inchS = userVarsName[4]; 
int[] wgPoints = new intfl { 1 10,112,1 14,1 17,120,123,126,129,132, 

135,138,141,144,147,150,155,165,501 }; 
Stringf] wgRanges = new String[] {"wt1","wt2","wt3","wt4","wt5","wt6", 

,, wt7 ,, > "wt8","wt9","wt1 0","wt1 1 ","wt1 2", 

"wt1 3","wt14","wt1 5","wt1 6","wt1 7","wt1 8"}; 

int inchl = lnteger.parselnt(inchS .substring^, inchS.Iength())); 
int inl = lnteger.parselnt{"5"); 
String pounds = userVarsName[5]; 
int poundl = (int)Double.parseDouble(poundS); 

if (feetS.equals("ft4") && inchl < 10 ){ 
inchS = "in 10"; 

} 

else if (feetS.equals("ft6") && inchl > 0 ){ 
inchS = "inO"; 

} 

// find weight range 

for (int i=0;i < 18; i++){ 
if (poundl < wgPointsfi] ) { 

pounds = wgRanges[i]; 
break; 

} 
} 

String fip = feetS+inchS+poundS; 
// find height/weight group 

String htwt= props.getProperty("user."+fip,"invalid_htwt"); 

userProfile[3] = htwt; 

if (htwt.equals("invalid_htwt")){ 

goodHeghtWeight = false; 

} 

return goodHeghtWeight; 
} 

/** 

* Find body type and endowement based on waist, 
* bust and hips dimensions 
*/ 

public boolean findBodyTypeEndw() 
{ 

boolean goodBodyEndw = true; 

doublet] bwPoints = new doublet] {1.275, 1-30, 1.35, 1.40, 1.45, 1.50,3.0 

}; 

double[] hwPoints = new double[] { 1.275, 1.30, 1.35, 1.40, 1.45, 1.50, 3.0 

}; 

String[] bwRanges = new String^ { "bw1", "bw2", "bw3", "bw4", "bw5", "bw6", 
"bw7" }; 

Stringf] hwRanges = newStringQ {"hw1", "hw2", "hw3", "hw4", "hw5", "hw6", 
"hw7" }; 

int[] brstPoints = new int[] {30,32,34,36,38,40,71 }; 
String [] brstRanges = new String [] 
{"br1","br2", ,, br3","br4", ,, br5","br6","br7"}; 
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String waists = userVarsName[6]; 
String busts = userVarsName[7]; 
String cupS = userVarsName[8]; 
String hipS = userVarsName[9]; 

String bwRange = null; 

String hwRange = null; 

String brstRange = null; 

double waistF = Double.parseDouble(waistS); 
double bustF = Double.parseDouble(bustS); 
double hipF = Double. parseDouble(hipS); 

double buwaF = bustF/waistF; 
double hiwaF = hipF/waistF; 

int i=0; 

for (i=0;i < 7; i++){ 
if (buwaF < bwPoints[i] ){ 

bwRange = bwRanges[i]; 
break; 

} 
} 

for (i=0;i < 7; i++){ 
if (hiwaF < hwPoints[i] ){ 

hwRange = hwRangesp]; 
break; 

} 

} 

String btyp = props.getProperty("user."+bwRange+hwRange,"invalid_btyp"); 
userProfile[4] = btyp; 

if (btyp.equals("invalid_btyp")){ 
goodBodyEndw = false; 

} 

// endowment 

int brstl = (int)bustF; 

for (i=0;i < 7; i++){ 
if (brstl < brstPoints[i] ){ 

brstRange = brstRanges[i]; 
break; 

} 

} 

String endw = 

props.getProperty("user."+brstRange+cupS,"invalid_endow"); 
userProfile[5] = endw; 
if (endw.equals("invalid_endow")){ 
goodBodyEndw = false; 

} 

return goodBodyEndw; 
} 

/" 

* Find hair/skin/eye combination 

*/ 

public boolean findHSEnumber() 
{ 

boolean goodShe = true; 
String retSHE = null; 
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String h = userVarsName[1 6]; 
h = h.substring(1,h.length()); 
String s = userVarsName[17]; 
s = s.substring(1,s.length()); 
String e = userVarsName[18]; 
e = e.substring(1,e.length()); 
// logger.debug(2,"h,s,e: "+h+",' , +s+" j "+e); 

int i=0; 
// hair 

String hair= props.getProperty("guides.hair"+h, "radiculess"); 
if (hair.equalsfradiculess")) 

goodShe = false; 
String skin = props.getProperty("guides.skin"+s, "radiculess"); 
if (skin.equalsfradiculess")) 

goodShe = false; 
String eye = props.getProperty("guides.eye"+e, "radiculess"); 
if (eye.equalsfradiculess")) 

goodShe = false; 

if (goodShe) 
{ 

retSHE = h+s+e; 

userProfile[12] = retSHE; 

} 

// logger.debug(2, " hair, skin, eye "+hair+","+skin+","+eye+" FOR SHE 

"+retSHE); 

return goodShe; 

} 



// {"evnt"/* 0 7,"sesn7* 1 7,"time'V* 2 7, 

// "htwt'7* 3 7,"btyp7* 4 7,"endw7* 5 7, 

// "fit"/* 6 7,"bst17* 7 7,"bst27* 8 */, 

// "wrst'V* 9 7,"sty1 '7* 1 0 7,"age7* 1 1 7, 

// "she"/* 12 7}; 

// {"evnt"/* 0 7,"sesn7* 1 7,"time7* 2 */,"feet'7* 3 */, 

// "inchs"/* 4 7,"pounds'7* 5 7,"waist7* 6 7, 

// "bust"/* 7 7,"cup7* 8 */,"hips7* 9 7,"bfit7* 10 7, 

// "bst17* 11 7,"bst27* 12 */,"wrst7* 13 7, 

// "styl"/* 14 */,"age7* 15 7,"hair7* 1 6 7, 

// "skin"/* 17 7,"eye7* 18 7,"zipcode7* 19 */}; 

/** 

* Find rest input number from arrays of templates 
*/ 

public void fmdRestlnput{intQ uChoice, Vector cArray){ 
String choice = "none"; 
int i,j,k; 

// fild rest of userProfile array 
userProfilefO] = userVarsName[0]; 
userProfile[1] = userVarsName[1]; 
userProfile[2] = userVarsName[2]; 
userProfile[6J = userVarsName[10]; 
userProfile [7] = userVarsName[11]; 
userProfile[8] = userVarsName[12]; 
userProfile[9] = userVarsName[13]; 
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userProfi!e[10] = userVarsName[14]; 
userProfile[11] = userVarsName[15]; 
into collndex= new intQ {1,13,17,20,29,34,38,41,48,55,64,75}; 
for (i=0; i< maxChoice ;i++ ){ 
choice = userProfile[i]; 

// find it position in arrays of columns 
for (k=colindex[i];k < cArray.size(); k++ ){ 
if 

(cArray.elementAt(k).toString().equals(choice)){ 

uChoice[i] = k; 
break; 

} 

} 

} 

// add SHE index 

for G=0;j < maxSheCol ;j++ ) 

{ 

choice = userProfile[12]; 

if (sheColArray.elementAtG).toString().equals(choice)) 
{ 

uChoice[12] = j+82; 
break; 

} 

} 

} 

/** 

* Main function to read and parse data file 

*/ 

public void getData() 
{ 

String lineText = null; 

int lineCount = 0; 

int tokenCount = 0; 
String[] tArray = new String[100]; 

for (intk=0;k<100 ;k++ ) 

{ 

try 

{ 

lineText = lnReader.readl_ine(); 
} catch (lOException e) { 

System.out.println( "IO error reading data file. " + e.toString() 

); 

System.exit(11); 

} 

if (lineText == null) 
{ 

break; 

} 

if (HneText.indexOf("DATA_START") != -1) 
{ 

continue; 

} 

if (lineText.indexOf("DATA_END") != -1) 
{ 

break; 
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lineCount++; 

String Tokenizer st= new String Tokenizer(lineText); 

tokenCount = 0; 

while (st.hasMoreTokens()) 

{ 

String token = st.nextToken(); 
tArray[tokenCount] = token; 
tokenCount++; 

} 

int cntNotO=0; 

float finalScore = (float)O.O; 

cntNotO = 0; 

boolean isNull = false; 

choiceVector[k] = new Vector(); 

choiceVectortk].insertElementAt(tArray[0],0); 
//if (lineCount == 15) 
//{ 

//print(" Line "+lineText); 

ID 

String sw = null; 
int wf = 1 ; 

for (inti=0;i<12 ;i++) 

{ 

sw = props.getProperty("applied.to.garment","0") ; 
if(sw.equals('T')) 
wf = 

lnteger.parselnt(props.getProperty("weighted.attrib."+i,"1")); 

String score = tArray[userChoicel[i]]; 
print("wF "+wf+" i "+i); 
if (score.equals("9")) 
{ 

isNull = true; 

choiceVector[k].insertElementAt(new Float(9.0),1); 
break; 

} 

if (!score.equals("0")) 
{ 

cntNotO++; 



} 



int partScore = lnteger.parselnt(score)/wf; 
finalScore += partScore; 

} 

if (isNull==false) { 
if(cntNotO==0){ 

choiceVector[k].insertElementAt(new Float(5.0),1); //Zero count 
} 

else { 

float realScore = (float)finalScore/cntNotO; 
choiceVector[k].insertElementAt{new Float(realScore),1 ); 

} 

} 



} 

} // end of read info 
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r 

* Print final scores 
*/ 

public void printFinalScore() 
{ 

for (int i=0;i<maxRow ;i++ ) 

{ 

String result = choiceVector[i].elementAt(1).toString(); 

if (result.indexOf(".") != -1 ) 

{ 

result = result.substring(0, resultindexOf(".")+2); 

} 

} 

} 

/** 

* Sort garments according their Scores 
7 

public void multChoice(int alnd, int aRet) 
{ 

int alndex = 0; 
intaNumb = maxAttrib; 

SortAttribsQ sa = new SortAttribs[aNumb]; 

for (int i=0;i<aNumb ;i++ ) 
{ 

String fName = attribName[alndex+i].toString(); 
float attf = 

Float.parseFloat(choiceVector[i].elementAt(1).toString()); 

Arrays ,fill(sa, i, i+1, new SortAttribs(attf, fName)); 

} 

Arrays.sort(sa, n ew M yCompa rator()); 
for (int i=0;i<aNumb ;i++ ) 

// logger.debug(579,sa[i].toString()); 



for (int i=0;i<maxRet ;i++) 

float fl = sa[i].getX(); 
if (fl < 9.0) 
{ 

resultVector[garmentReturns] = new Vector{); 
String s = ""+fl; 

s = s.substring(0, s.indexOf(".")+2); 
resultVector[garmentRetums].add(0, 

sa[i].getName()); 

// print("name "+sa[i].getName()+" score "+fl); 

resu ItVecto r[g arme ntRetu rns] .ad d ( 1 , s) ; 
garmentReturns++; 

} 

} 

} 

r 
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* Converted Garments Combination found to the garments type 

* and files 
*/ 

public void findGarments() 
{ 

for (int i=0;i < garmentReturns ;i++ ) 
{ 

String garmComb = resultVector[i].elementAt(0).toString(); // 

like gt1gt3 

String garml = garmComb.substring(0,3); // like gt1 
String garm2 = garmComb.substring(3, garmComb. Iength()); 

// like gt3 

intgnl = Integer.parselnt(garm1.substring(2,garm1.length())); 

//like 1 

intgn2 = Integer.parselnt(garm2.substring(2,garm2.length{))); 

//like 3 

garmentNumber[2*i] = gn1; 
garmentNumber[2*i+1] = gn2; 
recGarmentType[i] = new Vector(); 

String gtype = 
props.getProperty("garment."+garm1,"nonesence"); 

if (!gtype.equals("nonesence")) 
{ 

recGarmentType[i].add(gtype); // like shirts 

} 

gtype = 

props.getProperty("garment."+garm2,"nonesence"); // like skirts 
if (!gtype.equals("nonsence")) 
{ 

recGarmentType[i].add(gtype); 

} 

} 

} 

public void print(String s) 
{ 

System. out. println(s); 
} 
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#weighted inputs 

# switches 0 - not applied, 1 applied 
applied .to .garment=0 
applied. to.gfeatures=1 

#user specific events: e1-ec 
weighted. attrib.0=3 
#season: s1-s4 
weighted. attrib. 1=5 
#time of day: m1-m3 
weighted, attrib. 2=5 
#height/weight ratio: h1-h0 
weighted.attrib.3=2 
#body type: t1-t5 
weighted. attrib.4=1 
#endowment: d1-d4 
weighted. attrib. 5=3 
#body fitness level: f1-f3 
weighted. attrib.6=3 
#best feature 1 : b1-b7 
weighted. attrib. 7=3 
#best feature2: b8-be 
weighted.attrib.8=4 
#worst body feature: w1-w9 
weighted.attrib.9=3 
^personal style: p1-pb 
weighted.attrib.10=2 
Jyser age range: a1-a8 
weighted.attrib.11=4 
tfshe: 111-175 
weighted.attrib.12=2 
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4) the code that does the PROCESSING FOR CATEGORIZED OUTPUT - 
CHARACTERISTIC VALUES ffiqurel- 22V . 



r 

* Final version 3.0 

* Working and clean. 

* Generates sorted arrays of all scores. 

7 

// package guide; 
//import SortAttribs; 
//import MyComparator; 
//import GetGarment; 
// import utiLArguments; 
import java.util.*; 
import java.io.*; 

import java.io.OutputStreamWriter; 
import java.io.PrintWriter; 



public class GetScore3 { 



private static final int maxColl = 83; 
private static final int maxCol2 = 176; 
private static final int maxRow = 108; 
private static final int maxChoicel = 12; 
private static final int maxChoice2 = 1 ; 
private static final int maxChoice = 13; 

public static final int maxAttrib = 17; 

public static final int upperlnd = 0; 

public static final int necklnd = 1 ; 

public static final int clrlnd = 2; 

public static final int sieevlnd = 3; 

public static final int lintlnd = 4; 

public static final int backlnd = 5; 
public static final int collnd = 6; 

public static final int tnelnd = 7; 

public static final int matlnd = 8; 

public static final int patlnd = 9; 

public static final int leglnd = 10; 

public static final int slitlnd = 11; 

public static final int pleatlnd = 12; 

public static final int lowerlnd = 13; 

public static final int braslnd = 14; 

public static final int occsnlnd = 15; 

public static final int stylelnd = 16; 

public static final int upperRet = 1 ; 
public static final int neckRet = 2; 
public static final int clrRet = 1 ; 
public static final int sleevRet = 2; 
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public static final int lintRet = 2; 
public static final int backRet = 1 ; 
public static final int colRet = 6; 
public static final int tneRet = 2; 
public static final int matRet = 4; 
public static final int patRet = 3; 
public static final int legRet = 1 ; 
public static final int slitRet = 1 ; 
public static final int pleatRet = 1 ; 
public static final int lowerRet = 1 ; 
public static final int brasRet = 1 ; 
public static final int occsnRet = 1 ; 
public static final int styleRet = 1 ; 

private PrintWriter out1 ; 

private StringTokenizer st; 

private VectorQ dataRowVector = new Vector[maxRow]; 

public VectorQ resultVectorl = new Vector[maxAttrib]; 
public VectorQ resultVector2 = new Vector[maxAttrib]; 

private VectorQ attribFullName = new Vector[maxAttrib]; 

public LineNumberReader InReader = null; 

private intQ userChoice = new int[maxChoice]; 

public intQ attribNumber = new intQ {4,5,4,6,9,2,15,4,16,9,5,3,3,4,2,6,11}; 
private intQ attriblndex = new int[maxAttrib]; 



private String switch 1 = "no"; 
private String switch2 = "no"; 
private String switch3 = "allchoices"; 
private String switch4 = "no"; 
private int vectorNumb = 1; 
private int rowN = 0; 

private Vector colArray = null; 

// files passed as a parameters 
protected String dataFilel = null; 

public intQ garmentNumber = new int[20]; 

public Properties props; 
private Logger logger; 

/** 

* Constructor 
7 

GetScore3 (Properties props, intQ userChoice) { 
this.userChoice = (intQ)userChoice.clone(); 
this.props = props; 
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* get Column and Row information. 

* create column/Row arrays 
*/ 

public void getColumn() 
{ 



colArray = new Vector(); 

String gs = props.getProperty("guides.col1", null); 
String gs1 = props.getProperty("guides.shycol1", null); 
for (int i =0; i<maxCol1 ;i++ ) 
{ 

String gString = "guides.col"+i; 
colArray.add(props.getProperty(gString, null)); 

} 

for (int i =1 ; i<maxCol2;i++ ) 
{ 

String gString = "guides.shycoi"+i; 
colArray . add(props .getProperty(gString , n u 1 1 )); 

} 



create buffer reader for read actual data 



public void readData(String filel 
{ 

try 
{ 



{ 

switcM = props.getProperty("attrib.bestscore", "no"); 
switch2 = props.getProperty("attrib.allscore", "no"); 
switch3 = props.getPropertyfuser.from", "allchoices"); 
switch4 = props.getPropertyfchoice.show", "no"); 

// initialize out printing 
try 

{ 

// creating output files 

String dir = props.getProperty("out.directory", "d:/temp"); 
String fl = props. getProperty("out.file1", "Contest1.txt"); 
File f = new File(dir.fl); 
out1 = new PrintWriter( 
new FileWriter(f)); 
} catch(IOException e) {} 



String dir = props. getPropertyfgarment.directory", "d:/temp"); 
File dataListl = new File(dir,file1); 
// Definition for write portion 
String dirName = null; 

BufferedReader listln! = new Buffered Reader( 
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new Fi!eReader(datal_ist1)); 
InReader = new LineNumberReader(listlnl); 
} 

catch(FileNotFoundException e) 
{ // Stream creation exception 
System.err.println(e); 
return; 

} 

catch(IOException e) // File read exception 

{ 

printfError reading input file" + e ); 
return; 
} 



/** 

* Get row data from data files 
*/ 

public void getData() 
{ 

String lineText = null; 

int tokenCount = 0; 
Stringrj tArray = new String[300]; 

for (int j=0,k=0;j<150 ;k++,j++ ) 

{ 

try 

{ 

lineText = lnReader.readl_ine(); 
} catch (lOException e) { 

System.out.println( "IO error reading data file. " + e.toString{) ); 
System.exit(11); 

} 

if (lineText == null) 
{ 

break; 

} 

if (NneText.indexOf("DATA_START") != -1) 
{ 

k~; 

continue; 

} 

if (lineText.indexOf("DATA_END") != -1) 
{ 

break; 

} 

StringTokenizer st = new StringTokenizer(lineText); 

tokenCount = 0; 

while (st.hasMoreTokens()) 

{ 

String token = st.nextToken(); 
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tArray[tokenCount] = token; 
tokenCount++; 

} 

int cntNotO=0; 

float finalScore = (float)O.O; 

cntNotO = 0; 

boolean isNull = false; 

dataRowVector[k] = new Vector(); 

dataRowVector[k].insertElementAt(tArray[0],0); 

String sw = null; 

int wf = 1 ; 

for (int i=0;i<maxChoice ;i++) 

{ 

sw = props. getProperty("applied.to.gfeatures","0") ; 
if(sw.equals("1 ")) 
wf = 

lnteger.parselnt(props.getProperty("weighted.attrib."+i,"1")); 

String score = tArray[userChoice[i]]; 
if (score.equals("9")) 
{ 

isNull = true; 

dataRowVector[k].insertElementAt(new Float(9.0),1 ); 
break; 

} 

if (!score.equals("0")) 
{ 

cntNotO++; 

} 

finalScore += (float)lnteger.parselnt(score)/wf; 

out1.println(" finalscore: "+finalScore+" wf: "+wf+ " score: 

"+score+" i: "+i); 

out1 .flush(); 

if (k > 29 && k < 45) 
{ 

String color = props.getProperty("garment.attrib"+k,"none"); 
String colmn = 
props. getProperty("guides.col"+userChoice[i], "none"); 

// logger.debug(3," score for color = "+color+" equals 

"+finalScore+" under column "+colmn); 

} 

} 

if (isNull==false) { 
if (cntNotO==0){ 

dataRowVector[k].insertElementAt(new Float(5.0),1); // Zero count 

} 

else { 

float realScore = (float)finalScore/cntNotO; 
dataRowVector[k].insertElementAt(new Float(realScore),1 ); 

} 

} 

} 

} // end of read info 
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* Get the best scores 
7 

public void getMultChoice(int vectorNumb) 
{ 

this.vectorNumb = vectorNumb; 
attriblndex[0] = 0; 

for (int i=0;i<maxAttrib ;i++ ) 
{ 

if (i<maxAttrib-1 ) 
{ 

attriblndex[i+1] = attriblndex[i]+attribNumber[i]; 

} 

} 

for (int i=0;i<maxAttrib ;i++ ) 
{ 

attribFullName[i] = new Vector(); 

for (int j=0;j<attribNumber[i];j++ ) 
{ 

attribFullName[i]jnsertElementAt(props.getProperty("' , +i+'\garment.attrib"+j,nuII),j); 
// iogger.debug(3, " i: j: FullName 

"+props.getProperty(""+i+".garment.attrib"+j,null)); 
} 

} 

multChoice(upperlnd, upperRet); 

multChoice(necklnd, neckRet); 

multChoice(clrlnd, clrRet); 

multChoice(sleevlnd, sleevRet); 

multChoice(lintInd, lintRet); 

multChoice(backlnd, backRet); 

multChoice(collnd, colRet); 
multChoice(matlnd, matRet); 
muItChoice(tnelnd, tneRet); 

multChoice(patlnd, patRet); 

multChoice(leglnd , legRet); 

multChoice(slitlnd , slitRet); 

multChoice(pleatlnd , pleatRet); 

multChoice(lowerlnd , lowerRet); 

multChoice(braslnd , brasRet); 

multChoice(occsnlnd , occsnRet); 

multChoice(stylelnd , styleRet); 

} 

public void multChoice(int alnd, int aRet) 
{ 

int alndex = attriblndex[alnd]; 
int aNumb = attribNumber[alnd]; 

SortAttribsQ sa = new SortAttribs[aNumb]; 
boolean vectl = false; 
if (vectorNumb == 1 ) 
{ 
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resultVectoii [alnd] = new Vector(); 
vectl = true; 

} 

else 
{ 

resultVector2[alnd] = new Vector(); 
} 

for (int i=0;i<aNumb ;i++ ) 
{ 

String fName = attribFuiIName[alnd].elementAt(i).toString(); 
// logger.debug(3," alnd "+alnd+" i: fname "+fName); 

float attf = 

Float.parseFloat(dataRowVector[alndex+i].elementAt(1).toString()); 

Arrays.fill(sa, i, i+1 , new SortAttribs(attf, fName)); 

} 

Arrays.sort(sa,new MyComparator()); 

for (int i=0;i<aNumb ;i++ ) 

{ 

// print(sa[i].toString()); 
} 

if (vectl) 

resultVectorl [alnd].add(new Integer(aRet)); 

else 

resultVector2 [alnd] .add (new I nteger(a Ret)) ; 

for (int i=0;i<attribNumber[alnd] ;i++) 
{ 

Vector v = new Vector(); 

v.insertElementAt(new Float(sa[i].getX()), 0); 

String s = v.elementAt(0).toString(); 

s = s.substring(0, s.indexOf(".")+2); 

if (vectl) 

{ 

resultVectorl [alnd].add(sa[i].getName()); 
resultVectorl [alndj.add(s); 

} else { 

resultVector2[alnd].add(sa[i].getName()); 
resultVector2[alnd].add(s); 

} 

} 
} 

public void print(String s) 
{ 

System. out. println(s); 
} 
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5) the CATEGORIZED OUTPUT -CHARACTERISTIC SEARCH ORDER 
(fiqure1-26) : 

gtyp 

unit 

gocc 0 

gsty 1 

gcol 2 

gnck 3 

gslv 4 

gftt 5 

gftb 6 

glnt 7 

gleg 8 

gpat 9 

gtne 1 0 

gmat 1 1 

gslt 12 

gplt 13 

gbck 14 

gclr 1 5 

gbrs 1 6 



6) the OUTPUT CHARACTERISTIC PASSING CRITERIA (fiqurel- 26) : 

gocc 3 

gsty 3 

gcol 3 

gnck 3 

gslv 3 

gftt 9 

gftb 9 

glnt 5 

gleg 5 

gpat 9 

gtne 9 

gmat 9 

gslt 5 

gplt 5 

gbck 5 

gclr 9 

gbrs 9 



7) the SEARCHING SCHEMA/ RULES (figure 30) : 
/** 

* Version 3.0.6 

* Working and clean. 

* Works OK with servlets 

* Generated sorted arrays of all search scores. 

* Clean processLineQ for exclude '9' feature 
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*/ 

// package guide; 
//import SortAttribs; 
//import MyComparator; 
//import GetGarment; 
import PictComparator; 
import SortPicts; 
import java.util.*; 
import java.io.*; 

import java.io.OutputStreamWriter; 
import java.io. PrintWriter; 



public class GetScore5 { 



private static final int maxColl = 83; 
private static final int maxCol2 = 176; 
private static final int maxRow = 97; 
private static final int maxChoicel = 12; 
private static final int maxChoice2 = 1 ; 
private static final int maxChoice = 13; 

public static final int maxAttrib = 17; 

private StringTokenizer st; 

private Vector^ choiceVector = new Vector[maxRow]; 

public VectorQ resultVectorl = new Vector[maxAttrib]; 
public Vectorn resultVector2 = new VectorfmaxAttrib]; 

private Vector attribFullName = null; 

public LineNumberReader InReader = null; 

private int[] userChoice = new intfmaxChoice]; 

public intQ attribNumber = new intQ {4,5,4,6,9,2,1 5,4,16,9,5,3,3,4,2,6,1 1}; 
private int[] attriblndex = new int[maxAttrib]; 

private String switch 1 = "no"; 
private String switch2 = "no"; 
private String switch3 = "allchoices"; 
private String switch4 = "no"; 
private int vectorNumb = 1 ; 
private int rowN = 0; 

private Vector colArray = null; 

intQ s9on = new int[maxAttrib]; 

// files passed as a parameters 
protected String dataFilel = null; 
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private PrintWriter out1 ; 

private int bothHtt = 0; 

public Vector pictureVector = new Vector(); 

public Properties props; 

public Stringt] manuf_arr; 
public StringQ lname_arr; 
public StringQ sname_arr; 

public int score_arr[J; 
public int score1_arrQ; 

private boolean twoLine = true; 
private boolean printAII = false; 

private Logger logger; 

private int garmentNumberl = 0; 
private int garmentNumber2 = 0; 

public int start_p; 
public int end_p; 
public int aNumb; 

public SortPictsQ sp; 



* Constructor 
*/ 

GetScore5 (Properties props, intQ userChoice, int garmentNumberl , 

int garmentNumber2, VectorQ resultVectorl , VectorQ resultVector2 /*, 
PrintWriter out1*/){ 

this. props = props; 
this. userChoice = userChoice; 
this. garmentNumberl = garmentNumberl; 
this.garmentNumber2 = garmentNumber2; 
this. resultVectorl = resultVectorl ; 
this.resultVector2 = resultVector2; 
// this.outl = out1; 

} 

/** 

* Find array of picture file names 
*/ 

public void getPicture1() 
{ 

for (int i=0;i< userChoice. length ;i++) 
{ 

// print(""+userChoice[i]); 
} 

if (props. getProperty("print.score","none").equals("all")) 
{ 

printAII = true; 

} 
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getPictureData(); 
getSorted(pictureVector); 

r 

* Parsing picture data file 
*/ 

public void getPictureData() 
{ 

LineNumberReader InReaderl ; 
boolean good_data = true; 
int even_count = 0; 
int start_count=0; 

// open log file 

try 

{ 

// creating output files 

String dir = props.getPropertyfout.directory", "d:/temp"); 
String fl = props.getProperty("out.fiIe1", "Contest1.txt"); 
File f = new File(dir,fl); 
out1 = new PrintWriter( 
new FileWriter(f)); 
} catch(IO Exception e) {} 

// Get picture array start_stop 

if (garmentNumber2 == 0) 

twoLine = false; 
String garmCombo = ""+garmentNumber1+garmentNumber2; 
start_p = 

lnteger.parselnt(props.getProperty("picture.start"+garmCombo,"-1")); 
end_p = 

lnteger.parselnt(props.getProperty("picture.end"+garmCombo,"-1")); 

logger.debug(168," garm "+garmCombo+" start "+start_p+" end "+end_p); 
if (start_p == lnteger.parselnt("-1") || end_p == lnteger.parselnt("-1")) 
{ 

good_data = false; 

} 

if (good_data) 
{ 

start_count = start_p-1 ; 
// read picture data file 
try 
{ 

String dir = props. getProperty("garment.directory", "d:/temp"); 
File dataListl = new File(dir,"pictdata.txt"); 
Buffered Reader listlnl = new Buffered Reader( 
new FileReader(dataListl)); 
InReaderl = new LineNumberReader(listln1 ); 
} 

catch(FileNotFound Exception e) 
{ // Stream creation exception 
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System, err.println(e); 
return; 

} 

catch(10Exception e) // File read exception 

{ 

printfError reading input file" + e ); 
return; 

} 

String lineText = null; 

boolean data_start = false; 

boolean real_start = false; 
for (int i=0;i<1 000 ;i++ ) 

{ 

try 

{ 

lineText = InReaderl .readl_ine(); 

} catch (lOException e) { 
System. out. println( "10 error reading data file. " 

e.toString() ); 

System.exit(11); 

} 

if (NneText.indexOf("DATA_START") != -1) 

{ 

data_start = true; 
continue; 

} 

if (lineText == null) 

{ 

break; 

} 

if (lineText.indexOf("DATA_END") != -1) 
{ 

break; 

} 

// remove 1 more line 

if (data_start) 

{ 

data_start = false; 

real_start = true; 
continue; 

} 

// real start 
if (real_start) 
{ 

if (start_count- > 0) 

{ 

continue; 

} 

if (even_count > end_p - start_p +1 ) { 
break; 

} 

if (twoLine) 
{ 

if (even_count%2==0){ 
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processl_ine(1 JineText); 
even_count++; 

} else { 

processl_ine(2,lineText); 
even_count++; 

} 

} else { 
processl_ine(1 JineText); 
even_count++; 

} 

} 

} 

} 

} 

/** 

* Make real line for picture info processing 
7 

private void processLine(int In, String lineText) 
{ 

into attrib_start = new int[] {/*gocc791,/*gsty797, /*gcol730, /*gnck74, 
/*gslv713, /*gfft70, 

/*gftb785, /*glnt719, /*gleg774, /*gpat765, /*gtne745, /*gmat749, 
/*gslt779, /*gplt782, /*gbck728, /*gclr79, 

/*gbrs789}; 

intQ attrib_group = new intQ {/*gocc715,/*gsty716, /*gcol76, /*gnck*/1 , /*gslv*/3, 

/*gfft70, 

/*gftb713, /*glnt74, /*gleg710, /*gpat79, /*gtne77, /*gmat78, /*gslt71 1 , 
/*gplt712, /*gbck75, /*gclr72, 
/*gbrs714}; 

int top_depth = 0; 
int bot_depth = 0; 
int count = 0; 

boolean both_depth = false; 

int tokenCount = 0; 

StringD tArray = new String[300]; 

int minLength = lnteger.parselnt(props.getProperty("pict.path.filter","1")); 

if (In == 1) 

{ 

StringTokenizer st = new StringTokenizer(lineText); 
bothHit = 0; 

while (st.hasMoreTokens{)) 
{ 

String token = st.nextToken(); 
tArray[token Count] = token; 
tokenCount++; 

} 

// process this top line to the end 

top_depth = getDepth(1, attrib_start, attrib_group, tArray, resultVectorl ); 
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count++; 

// both_depth = top_depth > 0; 

} 

else 

StringTokenizer st = new StringTokenizer(lineText); 
while (st.hasMoreTokens()) 

String token = st.nextToken(); 
tArray[tokenCount] = token; 
token Count++; 

} 

// process this bottom line to the end 

bot_depth = getDepth(2,attrib_start, attrib_group, tArray, resultVector2); 
count++; 

} 

// process depth 
if (bothHit > minLength) { 
if (twoLine && In == 2) { 

pictureVector.add(new lnteger(bothHit)); 

pictureVector.add(new lnteger(top_depth)); 
pictureVector.add(newString(tArray[20])); 
pictureVector.add(new String(tArray[21]+"L.jpg")); 
pictureVector.add(new 

String(tArray[21]+"S.jpg")); 

} else if (ItwoLine) { 

pictureVector.add(new Integer(bothHit)); 
pictureVector.add(new lnteger(top_depth)); 
pictureVector.add(new String(tArray[20])); 
pictureVector.add(newString(tArray[21]+"L.jpg")); 
pictureVector.add(new 

String(tArray[21]+"S.jpg")); 
} 

} 



/** 

* Find how deep we can go 
*/ 

private int getDepth(int layer, intQ st_arr, intQ gr_arr, StringQ t_arr, VectorQ 
resultVector) 
{ 

int passed = 0; 

int thisHit = 0; 
// process top 
int i = 3, j = 0; 
StringQ nameArr; 
for (; i<maxAttrib+3 ) { 

// get token 
String tk = t_arr[i]; 
if (tk.iengthO == 1) { // single character 

int attrlndx = lnteger.parselnt(props.getProperty("attrib.numb"+tk,"-1")); 
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if (attrlndx >= 0) { 

int indx = st_arrO]+attrlndx; 
nameArr = new String[1]; 

nameArr[0] = 
props.getProperty("garment.attrib"+indx,"bad"); 



else 

} 



"nonsense"); 



} 

continue; 

else { // combinqation of characters 

nameArr = new String[tk.length()]; 
for (int k=0;k<tk.length() ;k++ ) { 

int indx = st_arr[j]+lnteger.parselnt(props.getProperty(gr_arr[j]+ 
"."+tk+"."+k,"-l")); 

nameArr[k] = props.getProperty("garment.attrib"+indx, 

} 
} 

passed = getCompare(nameArr, gr_arr[j], resultVector[gr_arr[j]], t_arr[21], j); 
if (passed > 0) { 

thisHit++; 

bothHit++; 
}else if (thisHit < 2) { 
break; 

} 

else if (passed < 0) { 
thisHit = -1 5; 

bothHit = -1 5; 
break; 

} 



out1.println(" Was file hit on top for file "+t_arr[21]+" Hits 
out1 .printlnf Was file hit on bottom for file "+t_arr[21]+" Hits 



} 

if (layer == 1){ 

"+thisHit+"j : "+j); 
} else { 

"+thisHit+" j; "+j); 
} 

out1 .flushQ; 
return thisHit; 

} 



* Make comparison, if not go try attribute 

* with next best score till score < 2.5 

7 

private int getCompare(StringQ nArray, int alndx, Vector scoreVector, String file, 

int col) 

{ 

Arrays.sort(nArray); 

String s9 = props. getProperty("pict.score.9","off"); 
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for (int k=0;k < maxAttrib ;k++ ) 
s9on[k] = lnteger.parselnt(props.getProperty("pict.on9."+k,"0")); 

} 

boolean sw9 = s9.equals("on"); 
for (int i=0;i<nArray.length ;i++ ) 

out1 .println(" Array nArray for file "+file+" at i: is "+nArray[i]); 

} 

int pos = -1 ; 
// first try to test if score '9' is presense. 
// If so no other testing 

for (int i=0,j = 1;i<(scoreVector.size()-1)/2 ;i++,j++ ) 

* String attrName = scoreVector.elementAt(2*i+1 ).toString(); 
double attrScore = 
Double.parseDouble(scoreVector.elementAt(2*i+2).toString()); 
if (attrScore == 9.0) 
{ 

pos = Arrays.binarySearch(nArray,attrName); 
out1 .printlnfGet Compare in '9' for file "+file+" attrName "+attrName+" Score 
"+attrScore+'' pos "+pos); 
out1 .flush(); 

if (pos >= 0 && sw9 && s9on[col] == 1 ) 
{ 

out1 .println("l should quit here"+ "sw9: "+s9on[col]+ "pos: "+pos); 

out1.flush(); 

return -1 ; 

} 

} 

} 

// try next in score 

for (int i=0,j = 1;i<(scoreVector.size()-1)/2 ;i++,j++ ) 

String attrName = scoreVector.elementAt(2*i+1).toString(); 
double attrScore = 
Double.parseDouble(scoreVector.elementAt(2*i+2).toString()); 

double pFilt = Double.parseDouble(props.getProperty("pict.filter","2.0")); 
if (attrScore < pFilt) 
{ 

pos = Arrays. binarySearch(nArray.attrName); 
out1 .println("Get Compare: for file "+file+" attrName "+attrName+" Score "+attrScore+" 
pos "+pos); 
out1 .flush(); 

if (pos >= 0) 
{ 

return 1; 

} 

} 

} 

if (pos < 0) 
{ 

return 0; 
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} 

return 1 ; 

} 

private boolean matchStyle(String styleBloc, int choice) 
{ 

String ch = props.getProperty("guides.col"+choice,"none"); 

StringQ styleNames = new String[styleBloc.length()]; 

for {int k=0;k<styleBloc.length() ;k++ ) 

{ 

int indx = 64+lnteger.parselnt(props.getProperty("16."+ 
styleBloc+"."+k,"-1")); 

styleNames[k] = props.getProperty("guides.col"+indx, 

"nonsense"); 

if (styleNames[k].equals(ch)) 
return true; 

} 

return false; 

} 

/** 

* Sort Array of objects 
*/ 

public void getSorted (Vector pVector) 
{ 

aNumb = pVector.size()/5; 
sp = new SortPicts[aNumb]; 
for (int i=0;i<aNumb ;i++ ) 
{ 

int score = lnteger.parselnt(pVector.elementAt(i*5).toString()); 
int score! = lnteger.parselnt(pVector.elementAt(i*5+1).toString()); 

String manuf = pVector.elementAt(i*5+2).toString(); 
String Iname = pVector.elementAt(i*5+3).toString(); 
String sname = pVector.elementAt(i*5+4).toString(); 
Arrays.fill(sp, i, i+1, new 
SortPicts(score,score1,manuf,lname,sname)); 
} 

Arrays. sort(sp, new PictComparator()); 

for (int i=0;i<aNumb ;i++ ) 

{ 

out1 .println(sp[i].toString()); 
out1.flush(); 

} 

int div = (int)(aNumb/5); 

int hm = div * 5; 
if (hm < aNumb) 
{ 

hm += 5; 

} 

// logger.debug(526," Pictures Number "+aNumb+" to whole Set "+hm); 

score_arr = new int[hm]; 
score1_arr = new int[hm]; 

manuf_arr = new String[hm]; 
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lname_arr = new String[hm]; 
sname_arr = new String[hm]; 
for (int i=0;i<aNumb ;i++) 
{ 

score_arr[i] = sp[i].getX(); 

score1_arr[i] = sp[i].getTop(); 
manuf_arr[i] = sp[i].getManuf(); 
!name_arr[i] = sp[i].getl_name(); 
sname_arr[i] = sp[i].getSname(); 

} 

for (int i=aNumb;i<hm ;i++) 
{ 

score_arr[i] = score_arr[aNumb-1]; 
score1_arr[i] = score1_arr[aNumb-1]; 

manuf_arr[i] = manuf_arr[aNumb-1]; 

lname_arr[i] = lname_arr[aNumb-1]; 

sname_arr[i] = sname_arr[aNumb-1]; 

} 

for (int i=0;i<hm ;i++) 
{ 

out1 .println(" i:"+i+" both_score "+score_arr[i]+" top_score 

"+score1_arr[i]+" manufact " 

+manuf_arr[i]+" Iname "+lname_arr[i]); 
out1 .flush(); 

} 



// ROW gtyp unit gocc/*91 7 gcol/*307 gfft /*0*/ gftb/*897 glnt/*1 9*/ 
// gleg/*74*/ gnck/*4*/ gslv/*137 gpat/*65*/ gtne/*457 gmat/*497 gslt/*797 
// gplt/*82*/ gbck/*28*/ gclr/*97 gbrs/*89*/ gsty manf filename 



public void print(String s) 
{ 

System.out.println(s); 
} 
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